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PRODUCT FEATURE AND RELATION COMPARISON SYSTEM 
FIELD OF THE INVENTION 

The present invention relates generally to the field of e-commerce and, more 
specifically, to knowledge representation and decision support regarding multiple items 
5 for users of a network-based transaction facility such as, for example, an Internet-based 
comparison shopping facility. 

BACKGROUND OF THE INVENTION 

An advantage offered by network-based transaction facilities (e.g., business-to- 

10 business, business-to-consumer and consumer-to-consumer Internet marketplaces and 
retailers) and on-line communities is that by using such facilities or communities, users 
may shop from a variety of merchants. 

The merchants may offer a variety of products or specialize in one type of 
product. Some users buy products after searching through the offerings of the various 

15 merchants and comparing the products and the prices. 

Recently comparison shopping facilities have developed that list various merchant 
offerings on one site to aid users in choosing from which merchant they should buy an 
item. These comparison shopping facilities present items by listing the price and name of 
the merchant offering the item. 

20 The user may choose items from the listing and go to each merchants site to learn 

more about each item or buy the item. Each available item from each manufacturer is 
listed separately. Thus, a user has to go to the comparison shopping facility either 
knowing what product to buy beforehand, and compare merchants and prices at the 
facility, or look at each item separately, by following a link to each merchant's site, to 

25 determine if the item is appropriate. Most comparisons performed by comparison 
shopping sites are based on the merchants offer price. That is, the result of the 
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comparison shopping is a list of items listed according to price. 
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SUMMARY OF THE INVENTION 

A method of presenting data regarding products is described. In one embodiment, 
feature categories are assigned to each product category based on available data. A 
weighted importance is assigned to each feature category of each product category based 
on the available data. The items in the product category are ranked according to the 
weighted importance of the feature categories of each item. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

The present invention will be understood more fully from the detailed description 
given below and from the accompanying drawings of various embodiments of the 
invention, which, however, should not be taken to limit the invention to the specific 
embodiments, but are for explanation and understanding only. 

Figure 1 illustrates an embodiment of a product feature and relation comparison 
system; 

Figure 2a is a flow diagram of an embodiment of a product feature and relation 

comparison system; 

Figure 2b is a flow diagram of another embodiment of a product feature and 

relation comparison system; 

Figure 3 is a flow diagram of another embodiment of a product feature and 
relation comparison system; 

Figure 4 is a more detailed flow diagram of the product feature and relation 
comparison system of Figure 2b; 

Figure 5 is a graph illustrating an embodiment of a feature contextualization 

system; 

Figure 6 is a flow diagram of an embodiment of a decision support system. 
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DETAILED DESCRIPTION 

A product feature and relation comparison system is disclosed. In the following 
description, numerous specific details are set forth such as configurations, media, etc., in 
order to provide a thorough understanding of the present invention. It will be apparent, 
5 however, to one skilled in the art that these specific details need not be employed to 

practice the present invention. In other instances, well known media or methods have not 
been described in detail in order to avoid obscuring the present invention. 

Some portions of the detailed descriptions which follow are presented in terms of 
algorithms and symbolic representations of operations on data bits within a computer 
10 memory. These algorithmic descriptions and representations are the means used by those 
skilled in the data processing arts to most effectively convey the substance of their work 
to others skilled in the art. An algorithm is here, and generally, conceived to be a self- 
consistent sequence of steps leading to a desired result. The steps are those requiring 
physical manipulations of physical quantities. Usually, though not necessarily, these 
15 quantities take the form of electrical or magnetic signals capable of being stored, 

transferred, combined, compared, and otherwise manipulated. It has proven convenient 
at times, principally for reasons of common usage, to refer to these signals as bits, values, 
elements, symbols, characters, terms, numbers, or the like. 

It should be borne in mind, however, that all of these and similar terms are to be 
20 associated with the appropriate physical quantities and are merely convenient labels 
applied to these quantities. Unless specifically stated otherwise as apparent from the 
following discussion, it is appreciated that throughout the description, discussions 
utilizing terms such as "processing" or "computing" or "calculating" or "determining" or 
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"displaying" or the like, refer to the action and processes of a computer system, or similar 
electronic computing device, that manipulates and transforms data represented as 
physical (electronic) quantities within the computer system's registers and memories into 
other data similarly represented as physical quantities within the computer system 
5 memories or registers or other such information storage, transmission or display devices. 
The present invention also relates to apparatus for performing the operations 
herein. This apparatus may be specially constructed for the required purposes, or it may 
comprise a general purpose computer selectively activated or reconfigured by a computer 
program stored in the computer. Such a computer program may be stored in a computer 
10 readable storage medium, such as, but is not limited to, any type of disk including floppy 
disks, optical disks, CD-ROMs, and magnetic-optical disks, read-only memories 
(ROMs), random access memories (RAMs), EPROMs, EEPROMs, magnetic or optical 
cards, or any type of media suitable for storing electronic instructions, and each coupled 
to a computer system bus. 
15 The algorithms and displays presented herein are not inherently related to any 

particular computer or other apparatus. Various general purpose systems may be used 
with programs in accordance with the teachings herein, or it may prove convenient to 
construct more specialized apparatus to perform the required method steps. The required 
structure for a variety of these systems will appear from the description below. In 
20 addition, the present invention is not described with reference to any particular 

programming language. It will be appreciated that a variety of programming languages 
may be used to implement the teachings of the invention as described herein. 
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Figure 1 illustrates an embodiment of a product feature and relation comparison 
system. The process may be performed by processing logic that may comprise hardware, 
software, or a combination of both. Note that although the process is described with 
reference to comparing features of products, it should be understood that the feature 

5 comparison methodology described herein may be applied to other types of services. 

Referring to Figure 1, a product feature and relation comparison system 100 is 
illustrated. Using a computer, a user able to view screens that transitions him through the 
comparison shopping process. Each of the displays represents a page that is displayed in 
response to some user action. When a user makes a selection or enters information on a 

10 page, a request is made to a server over a network to obtain another page. The request 
may cause the comparison shopping system to perform one or more functions at or under 
control of the server, with results being provided to user in the form of one or more web 
pages. 

Initially, a user, using a computer, which may be coupled to a network or stand 
15 alone, displays a first screen, or top page, 101 showing general categories for selection. 
The network may be a wide area network such as, for example, the Internet, or a 
proprietary network such as America Online®, CompuServe®, Microsoft Network®, or 
Prodigy®. 

At processing block 102, a user selects a general category. Optionally, the 
20 computer then displays drilldown pages 103 showing more specific categories. At 

processing block 104, the user selects a specific category. In response to selection of the 
specific category, the computer shows a product list window 120 with a dashboard 
control 1 10 at processing block 105. The user may have to select a certain number of 
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specific categories at processing block 103 before the computer displays the product list 
window 120. 

The dashboard control 1 10 may be used to filter the product list 120 by allowing 
the user to choose price, brand and features the user wants to see and/or believes to be 

5 important. In processing block 1 1 1 , the screen shows typical price range intervals for the 
product category chosen. At processing block 1 12, the user may select one of the price 
range intervals shown. In response to the price range selected by a user, the system 100 
then filters the product list at processing block 121 to show at window 120 only products 
within the specified price range. 

10 At processing block 1 13, the screen shows brands that make products in the 

product category chosen. At processing block 1 14, the user may select one or more of 
the brands shown on dashboard control 1 10. In response to a brand selection, the system 
100 filters the product list at processing block 123 to show window 120, it only products 
made by the specified brands. 

15 At processing block 1 15 of the dashboard control 1 10, the system shows product 

feature categories ranked by importance. At processing block 1 17, which may comprise 
a pop-up window, the system allows the user to define feature category constraints. In 
other words, the user is able to specify those product features that are important to him. 
In response to selection of these specific product features, the dashboard control 1 10 

20 shows active feature category constraints at processing block 1 16, if any. At processing 
block 126, the system 100 filters the product list to show in the product list window 120 
only products with the specified feature categories. 

The dashboard control 1 10 may also include pop-up windows 1 18 and 1 19. Pop- 
up window 118 shows a user buyer's guides for the product category chosen. Pop-up 

25 window 1 19 may show a user explanations of individual feature categories if the user 
wishes to see such explanations. 
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The product list window 120 may also include pop-up windows 122 and 124. 
Pop-up window 122 may show a review on a specific item in the product list window 
120, while pop-up window 124 may show the context for one feature of one item in the 
product list window against the competitive field, or other products in the product 

5 category chosen. The feature contextualization described with reference to pop-up 
window 124 will be discussed further below, with respect to Figure 5. 

At processing block 125, from the product list window, a user may select a 
specific product item to examine. In response to a selection, the system 100 expands the 
line item to show more details of the selected product item in processing block 126. The 

10 product list window may also be reorganized by selecting sort keys to re-sort the list. At 
processing block 127, a user may select sort keys such as, for example, price, memory 
size, or any other product features(s) that the user chooses. In response to the selection, 
at processing block 128, the system 100 re-sorts the list according to the users chosen sort 
method. 

15 Figure 2a is a flow diagram of an embodiment of a product feature in relation 

comparison system. At processing block 201, the system 100 assigns feature categories 
to each product category based on available data. Available data may include, for 
example, features that are important to a product or that occur in all brands of the same 
product extracted from literature about the product such as articles, reviews, etc. 

20 At processing block 202, a system 100 assigns weighted importance to each 

feature category based on the available data. The available data may include, for 
example, the number of times the feature is mentioned in product literature. The 
weighted importance may include assigning a numerical value between 0 and 100, for 
example. Alternatively, the weighted importance may include a different numerical scale 

25 or assigning a letter value to each feature category within a product category, or any other 
way of signifying a weighted importance. 
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The feature categories and weighted importance of each feature category are 
stored in a database (not shown) for each product category. It will be understood that the 
processes performed in processing blocks 201 and 202, and similar processes described 
below, may be edited by an editor. Such editing may, for example, ensure that the 
5 representation of the data in the database is correct (e.g., that a product category includes 
all of the correct feature categories with those categories weighted correctly). 

At processing block 203, the items in the product category are ranked according 
to the weighted importance of the feature categories. Thus, for a category such as, for 
example, personal digital assistant (PDA), the feature categories may include screen type, 
10 memory, upgradability, and functions, etc. If the available data indicates that the screen 
type and memory are more important for PDA's than upgradability or a number of 
functions, then screen type and memory will be given higher ratings than upgradability 
and functions available. Thus, PDA's may be ranked according to the average price first, 
then screen type, then memory, etc. In one embodiment, the ranking is stored in the 
15 database. In an alternate embodiment, the ranking is dynamically generated every time a 
person chooses a product category. 

Figure 2b shows a flow diagram of another embodiment of a product feature in 
relation comparison system. At processing block 201, the system 100 assigns feature 
categories to each product category based on available data. At processing block 202, the 
20 system assigns a weighted importance to each feature category based on available data. 
At processing block 204, the system allows the user to choose at least one feature 
category of importance to the user. For example, when the product category is PDAs, the 
user may choose the feature category corresponding to the number of functions included. 
In response to the user selection, at processing block 205, the system ranks the 
25 items within the product category based on the chosen categories and the weighted 

importance. In the example above, where the category is PDAs, the system re-sorts the 
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items within the product category to give more importance to the feature category of 

number of functions. 

Figure 3 is the flow diagram of an embodiment of a product feature and relation 
comparison system. At processing block 301, the system 100 assigns feature categories 

5 to each product category based on available data. At processing block 302, the system 
100 assigns a weighted importance to each feature category based on available data. At 
processing block 303, the system 100 ranks items in a product category according to the 
weighted importance of the feature categories. At processing block 306, the system 100 
assigns an essentiaLfeature tag to each essential feature category of a product category 

10 based on available data. Thus, for PDAs, for example the essential feature categories 
may include screen resolution and memory. All or any of the processes performed by 
processing blocks 301-303 and 306 may be edited by an editor to override automated 
assignments made by the system 100 based on available data. 

In the embodiment illustrated in Figure 3, the system 100 creates links within 

15 product categories to relate each product category to another product category where a 
relationship exists between the product categories. Many different processes may be 
used to relate the product categories to one another. 

In one embodiment, at processing block 307, the product category counter is set 
to 0 so that product_category (n) = product__category (0). At processing block 308, 

20 system 100 looks at product_category (n) to determine whether product_category (n) 
has all of the essential_feature categories of at least one other product category plus at 
least one other feature category that is not included in the other product category. 

If all the essential_feature categories plus one other feature category is included in 
product_category (n), a relation type of is_a_kind„of is assigned to product_category (n) 

25 at processing block 309. A relation type of is_a_kind„of represents that the product 

category is a subset of another product category. For example, Organizers & Notetakers 
is a subset of PDAs and PDAs are a subset of electronics. Thus, the category Organizers 
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& Notetakers would be assigned a relation type of is_aJcind_of PDA and the category 
PDA would be assigned a relation type of is_a_kind_of Electronics. 

At processing block 310, a link is created between product_category (n) and each 
related product category. Then, at processing block 31 1, n is compared to End to see if 
5 the product category just examined was the last product category in the database. If n 
equals the value of End, in block 3 1 1 , the product category was the last product category. 

If the product category is the last product category, then the system 100 creates 
hierarchical product category trees based on is_aJdnd_of links, at processing block 313. 
At processing block 312, if the product_category (n) is not the last product category, 
10 product_category (n) is incremented by one and the next product category is examined at 
processing block 308. 

When the links have been created, when a user chooses to look at the category 
Electronics, a is_aJdnd__of link between Electronics and other categories will prompt the 
system 100 to show the user a screen showing different branches of the Electronics 
15 category. Thus, in the example above, the user will see a screen that includes PDAs as a 
subcategory of Electronics. If the user chooses PDAs, the user will see a screen that 
includes Organizers & Notetakers as a subcategory of PDAs. 

Relation types other than "is„a_kind„of ' may be assigned to product categories. 
Other relation types include "is_a_part„of," "is_an_accessory_for " and 
20 "is_a„resource_for " A relation type of is_a_part_of may be assigned to a product 
category if the items in the product category are used only by inclusion in items of a 
second product category. For example, with respect to PDAs, this may include 
replacement memory chips, replacement screens, etc. 

A relation type of is_an_accessory_for may be assigned to a first product category 
25 if the items in the product category are used only in conjunction with a second product 
category although the items in the second product category may be used without the 
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items in the first product category. An example of this is Palm for the Palm V PDA with 
the external keyboard for Palm V being in the second product category. 

A relation type of is_a_resource_for may be assigned to a product category if the 
items in the product category are used only in conjunction with items in a second product 
5 category and is something that is consumable or exhaustible or has a fixed-limit life-span. 
The product categories that are assigned a relation type of is_a_resource_for may or may 
not be necessary for the base product. For example, printer cartridges are a resource for 
printers. 

Links may be created within each product category to reflect each assigned 

10 relation type. Thus, when a product list is displayed on product list window 120, a link 
may be included in the display to reflect that other items related to the items listed are 
available. Thus, the product list window 120 may include links indicating that "parts 
for", "accessories for", or "resources for" the items displayed in the product list window 
120 are available. The links may be used to go directly to the product list window 120 of 

15 the related product category. 

Figure 4 is a flow diagram of an embodiment of a product feature and relation 
comparison system. At processing block 401, a system 100 assigns feature categories to 
each product category based on available data. At processing block 402, the system 
assigns a weighted importance to each feature category based on available data. At 

20 processing block 412, the system 100 assigns a property type to each feature category 
based on the available data. The property type for each feature category is then stored in 
a database (not shown). The property types may include numerical property types, 
enumerated property types, text property types and meta property types. 

In one embodiment, numerical property types represent properties that are 

25 measured in a quantitative way. For example, numerical property types may include two 
sub-types: integer and decimal. Integer values are represented as -3, -2, -1, 0, 1, 2, 3, etc. 
Decimal properties are represented as real numbers such as, for example, 36.1 or 0.125, 
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etc. For example, on a VCR, the number of audio input jacks is an integer value, e.g., 4, 
while the width is in inches represented as a decimal number, e.g., 19.75". 

Enumerated property types are property types that have a fixed number of 
specified values. There are four sub-types of enumerated property types, including 
5 discrete, scalar, Boolean property types, and qualified Boolean property types. Discrete 
properties are values that do not admit of any evaluative scale, such as red, blue, yellow, 
etc., for example, where none of these values is inherently more valuable to a user than 
another. For example, the colors of a GameBoy Device (e.g., yellow, blue, etc.) are 
enumerated property types. 
10 Scalar values are enumerated values that do admit of an ordered scale, such as, for 

example, black-and-white, gray-scale, color, etc., where each value in the list does have 
an inherently greater or lesser value than each other value in the list. Boolean properties 
have a simple yes/no or a true/false valuation. Qualified Boolean properties have a 
yes/no/optional enumeration indicating either that the property exists (yes), it does not 
15 exist (no), or that it is an optional add-on to the product (optional). For example, some 
cameras have flash capability, some no flash capability, some can add a flash capability. 

Text properties are those properties that are represented by free form text. Text 
properties may or may not admit of a value. For example, an item having no text in a 
feature category may be of lesser value than an item having text in the same category. 
20 For example, football jerseys may have an "autographed by" field which would be 
represented in free form text. 

Meta properties are families of either Boolean or qualified Boolean properties that 
are grouped under a common label of which they are all instances. In the product 
category of television sets, for example, a Meta property grouping may be "special 
25 display functions." A "special display functions" grouping may include, for example, 

picture-in-picture, closed caption, Spanish language menus, etc. In this example, "special 
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display functions" is a meta property that groups together numerous Boolean properties 
(the television has it or it does not have it). 

All of the assignments of property type to feature categories may be reviewable 
and overrideable by editors. 

5 At processing block 422, evaluative metrics are assigned to each feature category 

based on the property type. Thus, any property type that may be compared may be 
assigned evaluative metrics describing how the properties or features in a feature 
category should be compared to distinguish between items in a property category. 

For example, if the property type is a numerical property type, then the features in 

10 each feature category are compared with respect to the numerical value for each item. 
Numerical properties may also be given a tag of "forward" or "backward" or "non- 
applicable" to indicate what numerical order is preferable from a user's point of view. If 
a larger number is more preferable from a user's point of view, a forward metric should 
be assigned; if a smaller number is preferable from a user's point of view, a backward 

15 metric should be assigned; or if a numerical property does not inherently indicate a 

preference from a user's point of view, a non-applicable metric may be assigned. A non- 
applicable metric may be applied to a piece of furniture such as a chair, for example, 
where the height of the chair does not matter. The property types and evaluative metrics 
are assigned based on available data. In one embodiment, the enumerated and Boolean 

20 types also have metrics. 

All of the assignments of evaluative metrics and forward/backward/non- 
applicable metrics may be overridden by editors. 

At processing block 423, the system checks to see if a user has chosen at least one 
feature category of importance to the user. If the user has chosen a category of 

25 importance to the user, the system 100 ranks each product category according to the 
user's chosen feature categories, the weighted importance of each feature category and 
the evaluative metric of each feature category. Thus, items ranked in product list window 
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120 would rank items giving priority to the user's chosen feature categories using the 
evaluative metric to order the items. Although the user chosen feature categories are 
given priority, the weighted importance of each feature category is also used in the 
ranking. In one embodiment, an algorithm to perform the ranking involves diverse 
5 factors including what this user has selected, what other users most frequently select, 
what is more frequently and prominently mentioned in product literature and reviews as 
measured statistically. 

If the user has not chosen at least one feature category of importance to the user at 
processing block 423, the system 100 proceeds to processing block 425. At processing 
10 block 425, the system 100 ranks the items in each product category according to the 
weighted importance of each feature category and the evaluated metrics of each feature 
category of the product category. 

Figure 5 is a graph illustrating an embodiment of a feature contextualization 
system. Graph 500 is an example of the contents of a pop-up window 124 showing the 
15 context for one feature of one product against the competitive field. As an example, 
figure 5 shows a feature contextualization image 500 illustrating the placement of a 
selected model of a PDA based on the memory of the PDA in the price range chosen by 
the user. The graph 500 shows random access memory (RAM) 501 in megabytes on the 
y axis. The graph 500 shows the model price along x access 502. 
20 The selected model 503 is compared to other models 510-516 which are priced in 

the price range of $200-$399. Thus, a user may see where the chosen model 503 stands 
with regard to the amount of memory available in the user's chosen price range of a field 
of products. This context sensitive presentation is possible because of the inclusion of 
the evaluative metrics and delineation of the property values throughout an entire 
25 category. Any feature category may be used to show the chosen product item against the 
competitive field. 
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Figure 6 is a flow diagram of an embodiment of a decision support system. At 
processing block 601, the system starts with user specified feature constraints. At 
processing block 602, the feature searches through a database to see if the desired 
features are found. If the desired features are found, the product items are listed at 

5 processing block 603. At processing block 604, the user selects the desired product. At 
processing block 605, the system 100 shows merchant offers for the selected product 
item. At processing block 606 the user selects the preferred offer. 

The merchant offers shown at processing block 605 may include buyer 
information data retrieved from available data. The buyer information data may also be 

10 organized into buyer information categories. The buyer information categories may 
include the price offered by the merchant, the shipping costs, the shipping method and 
availability of the item. The user may also choose the type of shipping method to 
determine the shipping costs and the amount of time needed for shipping. 

Each of the buyer information categories may also be ranked according to 

15 available data to show the merchant offers in a list. The ranking of the merchant offers 
may be based on weighted importance and evaluative metrics assigned to the buying 
information categories based on available data, as described with respect to the feature 
categories above. 

At processing block 607, the system 100 confirms that the item is in stock and 
20 available with the merchant chosen. If the item is confirmed to be in stock and available, 
the system 100 proceeds to the purchase process at processing block 608. 

If the item is not available with the chosen merchant or is not in stock, the system 
will search for the most similar offer from other merchants at processing block 613. If 
additional merchant offers are found, at processing block 614, the system 100 returns to 
25 processing block 607 to confirm whether the item is in stock and available. If the 
additional merchant offers are not found at processing block 615, the system looks for 
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other models with the same features and proceeds to processing block 602 to determine 
whether the desired features are in the database. 

If at processing block 602, the desired features are not found, then at processing 
block 609, the constraints on the less important features are relaxed. At processing block 

5 610, the system 100 determines if a near match is found. If a near match is found, the 
system proceeds to processing block 603 and lists the products found. If a near match is 
not found, then the system determines whether the constraints can be further relaxed and 
still have an acceptable match at processing block 611. For example, if a User wants a 
Sony TV 27" w/PIP price $369 and it is not available, one embodiment of the system 

10 may provide the following list of products that match the relaxed constraints. 

1 . Sony TV 27" w/PIP price $379 96% value match 

2. Philips TV 27" w/PIP price $369 91% value match 
Threshold 82% 3. Sony TV 25" w/PIP price $339 84% value match 

4. Sony TV 27" No PIP price $365 80% value match 

5. Sony TV 26" No PIP price $37 1 74% value match 

In one embodiment, the percentage value match is effected by direct features weighted 

differently as regards to how strongly the disparity will effect this number. Those above 

the threshold may be shown. 

If the constraints can be further relaxed, then the system 100 proceeds to 
15 processing block 609 to further relax the constraints on less important features. If the 

constraints cannot be further relaxed, the system displays a "sorry" message at processing 

block 612. The system may ask the user to specify other feature category constraints 

after displaying the "sorry" message at processing block 612. 

It will be appreciated that all of the components described are not necessary for 
20 this invention, and components may be added or deleted depending on the system 

requests. It will also be appreciated that all of the above processes for classifying or 
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weighting or evaluating data that is performed by automated means, such as software or 
hardware, may be overridden by editors. 

Whereas many alterations and modifications of the present invention will no 
doubt become apparent to a person of ordinary skill in the art after having read the 
foregoing description, it is to be understood that the various embodiments shown and 
described by way of illustration are in no way intended to be considered limiting. 
Therefore, references to details of various embodiments are not intended to limit the 
scope of the claims which in themselves recite only those features regarded as essential to 
the invention. 
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CLAIMS 

We claim: 



1 1 . A method of presenting data regarding products comprising: 

2 assigning feature categories to each product category based on available data; 

3 assigning a weighted importance to each feature category of each product 

4 category based on available data; 

5 ranking items in the product category according to the weighted importance of the 

6 feature categories included in each item 

7 receiving a selection of at least one feature category for a product type; 

8 assigning a greater weight to the selected category; and 

9 providing a ranked list of products based on the selected feature categories. 

1 2. The method of claim 1 wherein assigning a weighted importance to each feature 

2 category comprises assigning a score between 0 and 100 to each feature category in a 

3 product category. 

1 3. The method of claim 1 further comprising allowing a user to choose at least one 

2 feature category of importance to the user and ranking the items within the product 

3 category based on the feature category chosen by the user and the weighted importance of 

4 the feature categories of each item. 



1 4. The method of claim 1 further comprising: 

2 assigning a tag of essential_feature_category to each essential feature category of 

3 each product category based on available data; 

4 assigning a relation type of is_aJdnd_of to each product category if the product 

5 category includes all of the feature categories having the tag of 

6 essential_feature_category of another product category and includes at least one feature 
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I category that the other product category does not have wherein the product category is 

8 labeled a child category of the other product category and the other product category is 

9 labeled a parent category of the child product category; 

10 creating links within each product category to reflect the assigned is_aJdnd„of 

II relation; and 

12 using the is_a_kind_of relation to create at least one hierarchical product category 

13 tree wherein each hierarchical category tree has a heading product category that is only a 

14 parent category and changing the assigned weighted importance of a feature in the parent 

15 category changes the assigned weighted importance of the feature in the child category. 



1 5. The method of claim 4 wherein the assigned weighted importance of a feature in a 

2 child category overrides weighted importance assigned to the feature in the child 

3 category's parent category. 

1 6. The method of claim 1 further comprising: 

2 assigning a property type to each feature category; 

3 assigning evaluative metrics to each feature in each feature category based on the 

4 feature category property type and available data unless the property type is a discrete 

5 property type 

6 wherein items in each product category are ranked based on each item's evaluative 

7 metrics. 

1 7. The method of claim 6 farther comprising allowing a user to choose at least one 

2 feature of importance to the user and ranking items within a product category based on 

3 the chosen feature, the weighted importance of the feature categories and the evaluative 

4 metrics of the features within each feature category. 
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1 8. The method of claim 6 wherein assigning the property type comprises: 

2 assigning a property type of numerical_property if the features in the feature 

3 category are measured in a quantitative way; 

4 assigning a property type of enumerated_property if the features in the feature 

5 category have a fixed number of specified values including 

6 assigning a sub-property type of discrete if one feature in a feature 

7 category is not inherently more valuable than another, 

8 assigning a sub-property type of scalar if one feature in a feature category 

9 is inherently more valuable than another 

10 assigning a sub-property type of Boolean if the features in a feature 

1 1 category may have a valuation of only yes or no; 

12 assigning a sub-property type of qualified_Boolean if the feature in a 

13 feature category may have a valuation of yes, no, or optional; and 

14 assigning a property type of text_property if the features in the feature category 

15 are represented by free form text. 

1 9. The method of claim 6 further comprising: 

2 assigning a special meta-tag to a cluster of feature categories based on groupings 

3 derived from available literature if the features of the categories may have a value 

4 consisting of one of: yes, no or optional. 

1 10. The method of claim 9 further comprising: 

2 ranking items within a product category by the number of feature categories 

3 represented in an item within a cluster of feature categories. 

1 11. The method of claim 6 further comprising assigning a evaluative tag of 

2 forward„metric to a feature category if a value of an item in a product category increases 
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3 as a numerical valuation of features within the feature category increases based on 

4 available data; 

5 assigning a evaluative tag of backward_metric based on available data to a feature 

6 category if the value of an item in a product category decreases as numerical valuation of 

7 features within the feature category increases; and 

8 assigning a evaluative tag of non_applicable based on available data to a feature 

9 category if the value of an item in a product category does not change with numerical 

10 valuation of features within a feature category 

1 1 wherein the evaluative tag is used to rank items in a product category. 

1 12. The method of claim 6 further comprising presenting a user with a choice of at 

2 least two feature categories for sorting; 

3 sorting items within a product category according to the user chosen feature 

4 categories, the weighted importance of all the feature categories and the evaluative 

5 metrics of the feature categories applied to the features within the feature categories. 

1 13. The method of claim 1 further comprising deriving ranges of values within feature 

2 categories from available data to determine natural ranges for grouping numerical 

3 features. 

1 14. The method of claim 13 further comprising presenting a user with sub-ranges of 

2 values within feature categories for filtering product data to be presented. 

1 15. The method of claim 1 further comprising applying statistical analysis to derive 

2 the placement of an item within a product category with respect to at least one feature 

3 category. 
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1 16. The method of claim 15 wherein statistical analysis is applied to derive the 

2 placement of an item within a product category with respect to two feature categories. 

1 17. The method of claim 15 further comprising graphing the placement of an item 

2 within a product category. 

1 18. The method of claim 17 further comprising presenting the user with a graph of the 

2 placement of a user chosen item with respect to other items in a product category based 

3 on the at least one feature category. 

1 19. The method of claim 1 further comprising: 

2 assigning relation types to each product category to relate each product category 

3 to at least one other product category if a related product category exists including 

4 assigning a relation type of is_a_kind„of if a product category shares all 

5 the feature categories of another product category and has at least one feature category 

6 that the second product category does not have, 

7 assigning a relation type of is„a_part_of if items in a product category are 

8 used only by inclusion in items in a second product category, 

9 assigning a relation type of is_an_accessory_for if items in a first product 

10 category are used only in conjunction with a second product category although the items 

1 1 in the second product category may be used without the items in the first product 

12 category, 

13 assigning a relation type of is__a_resource_for if items in a first product 

14 category are used only in conjunction with items in a second product category and must 

15 be replaced or replenished; and 

16 creating links within each product category to reflect each assigned relation type. 
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1 20. The method of claim 19 further comprising creating hierarchical category trees 

2 using the is_a_kind_of relation type assignments wherein each hierarchical category tree 

3 has one product category that is only a parent category. 

1 21 . The method of claim 1 wherein the items in each product category are items 

2 offered for sale by merchants. 

1 22. The method of claim 1 wherein the items in each product category are items 

2 offered for sale on the internet. 

1 23. The method of claim 1 further comprising assigning a weighted importance to 

2 buying information categories of each item based on available data and ranking 

3 merchants offering each item based on the weighted importance of the buying 

4 information categories. 

1 24. The method of claim 23 further comprising assigning evaluative metrics to the 

2 buying information categories of the product categories and ranking the merchants 

3 offering each item based on the weighted importance of the buying information 

4 categories and evaluative metrics of the buying information categories. 

1 25. The method of claim 23 wherein the buying information categories include price, 

2 shipping costs, shipping method and availability. 

1 26. The method of claim 1 further comprising: 

2 allowing a user to choose an item from a list of items in a product category; and 

3 displaying the merchants selling the chosen item. 
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1 27. The method of claim 26 further comprising displaying buying information for 

2 each merchant selling the chosen item. 

1 28. The method of claim 26 further comprising displaying the merchant buying 

2 information in a ranked list wherein the merchant buying information is ranked according 

3 to a weighted importance assigned to each buying information category and evaluative 

4 metrics applied to each buying information category based on available data. 



1 29. A method of presenting data regarding products comprising: 

2 assigning feature categories to each product category based on available data; 

3 assigning a property type to each feature category; 

4 assigning evaluative metrics to each feature in each feature category based on the 

5 property type and available data unless the property type is a discrete property type 

6 wherein items in each product category may be ranked based on each item's 

7 evaluative metrics. 

1 30. A system for presenting data regarding products comprising: 

2 means for assigning feature categories to each product category based on 

3 available data; 

4 means for assigning a weighted importance to each feature category of each 

5 product category based on available data; 

6 means for ranking items in the product category according to the weighted 

7 importance of the feature categories included in each item 

8 means for receiving a selection of at least one feature category for a product type; 

9 means for assigning a greater weight to the selected category; and 

10 means for providing a ranked list of products based on the selected feature 

11 categories. 
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1 31. A computer readable storage medium containing executable computer program 

2 instructions which when executed cause a digital processing system to perform a method 

3 for presenting data regarding products, said method comprising: 

4 assigning feature categories to each product category based on available data; 

5 assigning a weighted importance to each feature category of each product 

6 category based on available data; 

7 ranking items in the product category according to the weighted importance of the 

8 feature categories included in each item 

9 receiving a selection of at least one feature category for a product type; 

10 assigning a greater weight to the selected category; and 

1 1 providing a ranked list of products based on the selected feature categories. 
12 
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ABSTRACT 

A method of presenting data regarding products. Feature categories are assigned 
to each product category based on available data. A weighted importance is assigned to 
each feature category of each product category based on the available data. The items 
in the product category are ranked according to the weighted importance of the feature 
categories of each item, and the evaluation metrics of each feature category. 
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DECLARATION AND POWER OF ATTORNEY FOR PATENT APPLICATION 
As a below named inventor, I hereby declare that: 

My residence, post office address and citizenship are as stated below, next to my name. 

I believe I am the original, first, and sole inventor (if only one name is listed below) or an original, 
first, and joint inventor (if plural names are listed below) of the subject matter which is claimed and 
for which a patent is sought on the invention entitled 

"PRODUCT FEATURE AND RELATION COMPARISON SYSTEM" 



the specification of which 

X is attached hereto. 

was filed on . _ as 

United States Application Number . 

or PCT International Application Number . 

and was amended on ■ 

(if applicable) 

I hereby state that I have reviewed and understand the contents of the above-identified 
specification, including the claim(s), as amended by any amendment referred to above. I do not 
know and do not believe that the claimed invention was ever known or used in the United States of 
America before my invention thereof, or patented or described in any printed publication in any 
country before my invention thereof or more than one year prior to this application, that the same 
was not in public use or on sale in the United States of America more than one year prior to this 
application, and that the invention has not been patented or made the subject of an inventor's 
certificate issued before the date of this application in any country foreign to the United States of 
America on an application filed by me or my legal representatives or assigns more than twelve 
months (for a utility patent application) or six months (for a design patent application) prior to this 
application. 

I acknowledge the duty to disclose all information known to me to be material to patentability as 
defined in Title 37, Code of Federal Regulations, Section 1 .56. 

I hereby claim foreign priority benefits under Title 35, United States Code, Section 119(a)-(d), of any 
foreign application(s) for patent or inventor's certificate listed below and have also identified below 
any foreign application for patent or inventor's certificate having a filing date before that of the 
application on which priority is claimed: 
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I hereby claim the benefit under Title 35, United States Code, Section 120 of any United States 
application(s) listed below and, insofar as the subject matter of each of the claims of this application 
is not disclosed in the prior United States application in the manner provided by the first paragraph 
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known to me to be material to patentability as defined in Title 37, Code of Federal Regulations, 
Section 1 .56 which became available between the filing date of the prior application and the national 
or PCT international filing date of this application: 
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States Code and that such willful false statements may jeopardize the validity of the 
application or any patent issued thereon. 
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Kurt P. Leyendecker, Reg. No. 42,799; Michael J. Mallie, Reg. No. 36,591; Andre L. Marais, under 37 
C.F.R. § 10.9(b); Paul A. Mendonsa, Reg. No. 42,879; Darren J. Milliken, Reg. 42,004; Lisa A. Norris, 
Reg. No. 44,976; Chun M. Ng, Reg. No. 36,878; Thien T. Nguyen, Reg. No. 43,835; Thinh V. Nguyen, 
Reg. No. 42,034; Dennis A. Nicholls, Reg. No. 42,036; Daniel E. Ovanezian, Reg. No. 41 ,236; Marina 
Portnova, Reg. No. P45,750; Babak Redjaian, Reg. No. 42,096; William F. Ryann, Reg. 44,313; James 
H. Salter, Reg. No. 35,668; William W. Schaal, Reg. No. 39,018; James C. Scheller, Reg. No. 31,195; 
Jeffrey Sam Smith, Reg. No. 39,377; Maria McCormack Sobrino, Reg. No. 31,639; Stanley W. Sokoloff, 
Reg. No. 25,128; Judith A. Szepesi, Reg. No. 39,393; Vincent P. Tassinari, Reg. No. 42,179; Edwin H. 
Taylor, Reg. No. 25,129; John F. Travis, Reg. No. 43,203; George G. C. Tseng, Reg. No. 41,355; Joseph 
A. Twarowski, Reg. No. 42,191; Lester J. Vincent, Reg. No. 31,460; Glenn E. Von Tersch, Reg. No. 
41,364; John Patrick Ward, Reg. No. 40,216; Mark L. Watson, Reg. No. P46,322; Thomas C. Webster, 
Reg. No. P46,154; Charles T. J. Weigell, Reg. No. 43,398; Kirk D. Williams, Reg. No. 42,229; James M. 
Wu, Reg. No. 45,241; Steven D. Yates, Reg. No. 42,242; and Norman Zafman, Reg. No. 26,250; my 
patent attorneys, and Justin M. Dillon, Reg. No. 42,486; my patent agent, of BLAKELY, SOKOLOFF, 
TAYLOR & ZAFMAN LLP, with offices located at 12400 Wilshire Boulevard, 7th Floor, Los Angeles, 
California 90025, telephone (310) 207-3800, and James R. Thein, Reg. No. 31,710, my patent attorney. 
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APPENDIX B 



Title 37, Code of Federal Regulations, Section 1 .56 
Duty to Disclose Information Materia! to Patentability 

(a) A patent by its very nature is affected with a public interest. The public interest is best served, 
and the most effective patent examination occurs when, at the time an application is being examined, the 
Office is aware of and evaluates the teachings of all information material to patentability. Each individual 
associated with the filing and prosecution of a patent application has a duty of candor and good faith in 
dealing with the Office, which includes a duty to disclose to the Office all information known to that individual 
to be material to patentability as defined in this section. The duty to disclosure information exists with respect 
to each pending claim until the claim is cancelled or withdrawn from consideration, or the application becomes 
abandoned. Information material to the patentability of a claim that is cancelled or withdrawn from 
consideration need not be submitted if the information is not material to the patentability of any claim 
remaining under consideration in the application. There is no duty to submit information which is not material 
to the patentability of any existing claim. The duty to disclosure all information known to be material to 
patentability is deemed to be satisfied if all information known to be material to patentability of any claim 
issued in a patent was cited by the Office or submitted to the Office in the manner prescribed by §§1 .97(b)-(d) 
and 1.98. However, no patent will be granted on an application in connection with which fraud on the Office 
was practiced or attempted or the duty of disclosure was violated through bad faith or intentional misconduct. 
The Office encourages applicants to carefully examine: 

(1 ) Prior art cited in search reports of a foreign patent office in a counterpart application, and 

(2) The closest information over which individuals associated with the filing or prosecution of a 
patent application believe any pending claim patentably defines, to make sure that any material information 
contained therein is disclosed to the Office. 

(b) Under this section, information is material to patentability when it is not cumulative to 
information already of record or being made or record in the application, and 

(1 ) it establishes, by itself or in combination with other information, a prima facie case of 
unpatentability of a claim; or 

(2) ft refutes, or is inconsistent with, a position the applicant takes in: 

(i) Opposing an argument of unpatentability relied on by the Office, or 

(ii) Asserting an argument of patentability. 

A prima facie case of unpatentability is established when the information compels a conclusion that a claim is 
unpatentable under the preponderance of evidence, burden-of-proof standard, giving each term in the claim 
its broadest reasonable construction consistent with the specification, and before any consideration is given to 
evidence which may be submitted in an attempt to establish a contrary conclusion of patentability. 

(c) Individuals associated with the filing or prosecution of a patent application within the 
meaning of this section are: 

(1 ) Each inventor named in the application; 

(2) Each attorney or agent who prepares or prosecutes the application; and 

(3) Every other person who is substantively involved in the preparation or prosecution of the 
application and who is associated with the inventor, with the assignee or with anyone to whom there is an 
obligation to assign the application. 

(d) Individuals other than the attorney, agent or inventor may comply with this section by 
disclosing information to the attorney, agent, or inventor. 
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